import json
from django.conf import settings
from django.utils.deprecation import MiddlewareMixin
from django.contrib.auth.models import AnonymousUser
from system.models import OperationLog
from utils.request_util import get_request_user, get_request_ip, get_request_data, get_request_path, get_os, \
    get_browser, get_verbose_name
import re
class ApiLoggingMiddleware(MiddlewareMixin):
    """
    用于记录API访问日志中间件
    """

    def __init__(self, get_response=None):
        super().__init__(get_response)
        self.enable = getattr(settings, 'API_LOG_ENABLE', None) or False
        self.methods = getattr(settings, 'API_LOG_METHODS', None) or set()
        self.operation_log_id = None

    @classmethod
    def __handle_request(cls, request):
        request.request_ip = get_request_ip(request)
        request.request_data = get_request_data(request)
        request.request_path = get_request_path(request)

    def __handle_response(self, request, response):
        # request_data,request_ip由PermissionInterfaceMiddleware中间件中添加的属性
        body = getattr(request, 'request_data', {})
        # 请求含有password则用*替换掉(暂时先用于所有接口的password请求参数)
        if isinstance(body, dict) and body.get('password', ''):
            body['password'] = '*' * len(body['password'])
        if not hasattr(response, 'data') or not isinstance(response.data, dict):
            response.data = {}
        try:
            if not response.data and response.content:
                content = json.loads(response.content.decode())
                response.data = content if isinstance(content, dict) else {}
        except Exception:
            return
        user = get_request_user(request)
        info = {
            'request_ip': getattr(request, 'request_ip', 'unknown'),
            'creator': user if not isinstance(user, AnonymousUser) else None,
            'dept_belong_id': getattr(request.user, 'dept_id', None),
            'request_method': request.method,
            'request_path': request.request_path,
            'request_body': body,
            'response_code': response.data.get('code'),
            'request_os': get_os(request),
            'request_browser': get_browser(request),
            'request_msg': request.session.get('request_msg'),
            'status': True if response.data.get('code') in [0, ] else False,
            'json_result': {"code": response.data.get('code'), "msg": response.data.get('msg')},
        }
        operation_log = OperationLog.objects.create(
            request_method=info.get('request_method'),
            request_ip=info.get('request_ip'),
            creator=info.get('creator'),
            dept_belong_id=info.get('dept_belong_id'),
            request_path=info.get('request_path'),
            request_body=info.get('request_body'),
            request_os=info.get('request_os'),
            response_code=info.get('response_code'),
            request_browser=info.get('request_browser'),
            request_msg=info.get('request_msg'),
            status=info.get('status'),
            json_result=info.get('json_result'),
            )
        # if not operation_log.request_modular and settings.API_MODEL_MAP.get(request.request_path, None):
        #     operation_log.request_modular = settings.API_MODEL_MAP[request.request_path]
        #     operation_log.save()
    # def process_view(self, request, view_func, view_args, view_kwargs):
    #     print(request.request_path)
    #     print(view_args)
    #     if view_kwargs is not None:
    #         str(request.request_path)
    #     if self.enable:
    #         if request.method in self.methods:
    #             log = OperationLog(request_modular=get_verbose_name())
    #             log.save()
    #             self.operation_log_id = log.id

        return

    def process_request(self, request):
        self.__handle_request(request)

    def process_response(self, request, response):
        """
        主要请求处理完之后记录
        :param request:
        :param response:
        :return:
        """
        if self.enable:
            if self.methods == 'ALL' or request.method in self.methods:
                self.__handle_response(request, response)
        return response